EXAMENUL PENTRU OBŢINEREA ATESTATULUI PROFESIONAOLĂ 
LA DISCIPLINA INFORMATICĂ 
2017 
SUBIECTE DE TIP II - PROGRAMARE 


1. Fisierul text numere.in conține pe prima linie un număr natural n (0<n<1000), iar pe a doua 
linie n numere naturale cu cel mult 9 cifre fiecare, despărțite prin câte un spațiu. Scrieţi un 
program C/C++ care citeşte toate numerele din fişierul numere.in si care afişează în fişierul 
numere.out toate numerele din fişierul de intrare care au toate cifrele pare. 
Exemplu: 

numere.in  numere.out 

4 24 2462 

23 24 555 2462 


include <iostream> 
include <fstream> 
using namespace std; 
int par(int m) 
| 
while(m%2==0 && m!=0) 
{ 
m/=10; 
) 
if(m==0) 
return 1; 
else return 0; 
) 
int main() 
| 
int n,i,X; 
ifstream f1("numere.in"); 
ofstream f2("numere.out”); 
tls>n; 


for(i=1:i<=n:i++) 
| 
f1>>x; 
if(par(x)==1) 
| 


f2<<x<<''; 


} 
} 


return 0; 


) 


2. Fisierul atestat.in contine pe prima linie un numär natural n de cel mult 9 cifre. Scrieti 
un program C++ care citeşte din „atestat.in” numărul n si care scrie în fișierul atestat.out pe 
prima linie, cifrele de rang par separate printr-un spaţiu (rangul se numerotează de la dreapta la 
stânga începând cu cifra unităților care va avea rangul 1); Exemplu: 

Dacă fişierul atestat.in conţine: 

32245673 atunci atestat.out va avea următorul 

conţinut: 

7523 


“include <iostream> 
tinclude <fstream> 
using namespace std; 
int main() 
{ 

int n,i,x[1001],m=0; 


ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 
fl>>n; 


while(n) 
| 
x[++m]=n%10; 
n/=10; 
) 
for(i=2;i<=m;i+=2) 
f2<<x[i]<<' '; 
return O; 


3. in fisierul date.in pe prima linie este memorat un numär natural n iar pe urmätoarea 
linie sunt memorate n numere naturale separate prin spatiu, numere de maxim 9 cifre. Se cere 
sä se afiseze pe prima linie a fisierului date.out cel mai mic numär impar si pozitia primei 
aparitii a acestuia. Dacä nu existä astfel de numere sä se afiseze mesajul "NU EXISTA"; 


Exemplu: 
date.in date.out 
4 33 2 


24 33 2343 33 


#include <iostream> 
#include <fstream> 
using namespace std; 
int main() 


i 


int n,1,xX,poz=0,mini= 100000; 


ifstream f1("date.in"); 
ofstream f2("date.out"); 
f1>>n; 
for(i=1:i<=n:i++) 


| 


f1>>x; 
1f(x%2!=0) 
if(mini>x) 
| 
mini=x; 
poz=i; 
) 
) 


f2<<mini<<' '<<poz; 


return 0; 


) 


4. Fişierul date.in conţine cel mult 50 de numere naturale, numerele fiind separate prin câte un 
spațiu. Fiecare număr are cel mult 4 cifre. Scrieţi un program C/C++ care afişează pe câte o 
linie a fişierului date.out, fiecare număr citit, în ordinea citirii, şi divizorii proprii ai acestuia; 
Exemplu: dacă fişierul date.in conţine valorile: 

23 12 100 36 atunci se va scrie în 
fişierul date.out: 

23 

12 2 346 

100 2 4 5 10 20 25 50 

36 23469 12 18 


+include <iostream> 

include <fstream> 

using namespace std; 

int main() 

| 
int n=1,i,x,d,nr=0,aux,dmax=0; 
ifstream f1("date.in"); 
ofstream f2("date.out"); 


while(f1>>x) 
(f2<<x<<''; 
d=2: 
for(d=2;d<x:d++) 
If(x%d==0) 
f2<<d<<' '; 
f2<<endl; 
) 


return O; 


) 


5. Fişierul text Numere.in conţine cel mult 1000 de numere naturale cu cel mult patru cifre 
fiecare, despărțite prin câte un spaţiu. Afisati pe ecran primul număr prim din fişier. Dacă 
fişierul nu conţine nici un astfel de număr, atunci se va scrie mesajul NU EXISTA. 
Exemplu: dacă fişierul Numere.in are următorul conținut: 


3 


300 11 44 25713 
pe ecran se va afişa 11, 


include <iostream> 
include <fstream> 
using namespace std; 
int prim(int x) 
{ 
int d=2; 
while(d*d<=x && x%d!=0) 
d++; 
if(d*d>x) 
return 1; 
else return 0; 
) 
int main() 
| 
int n=1,1,x,0k=0; 
ifstream f1("Numere.in"); 
ofstream f2("Rezultate.out"); 
fl>>n; 
for(i=1;i<=n;i++) 
159022 % 
1f(prim(x)==1) 


(cout<<x;i=n+1:0k=1;) 


cout<<"NU EXISTA"; 
return 0; 


6. În fișierul numere.in sunt memorate cel mult 1000 de numere naturale de cel mult 4 cifre 


fiecare. 


Scrieţi un program care citeşte numerele din fișierul numere.in și afișeză pe prima linie a 
fişierului numere.out cel mai mare număr palindrom din fişierul numere.in; Exemplu: 


numere.in 


10 101 23 44 676 43 88 201 202 124 141 90 


include <iostream> 
include <fstream> 
using namespace std; 
int palindrom(int x) 
fint aux=x,inv=0; 
while(aux) 
{ 
inv=aux% 10+inv* 10; 
aux/=10; 


numere.out 
676 


| 
return X==inv; 
) 
int main() 
| 
int n=1,i,x,maxpal=0; 
ifstream f1("numere.in"); 
ofstream f2("numere.out”); 
f1>>n; 
for(i=1;i<=n;i++) 
{ 
f155x: 
if(palindrom(x)==1 && x>maxpal) 
maxpal=x; 
) 


f2<<maxpal<<endl; 


return 0; 


) 


7. Fisierul atestat.in conţine două linii. Pe prima linie este scris un număr natural nenul n, 
(5<n<30). Pe cea de-a doua linie a fişierului sunt scrise n numere naturale separate prin câte un 
spațiu, formate fiecare din cel mult 4 cifre, reprezentând un şir de n numere naturale nenule. 
Cel puțin unul din cele n numere din sir este număr impar. 

Să se realizeze un program în limbajul C/C++, care scrie în fişierul atestat.out pe prima linie, 
separate printr-un spaţiu, numărul cifrelor numerelor impare din şir. Exemplu: 


atestat.in atestat.out 
6 312 
1232 243 98 3 242 27 


include <iostream> 
tinclude <fstream> 
int nrcifre(int m) 
(int nr=0; 
while(m) 
| 
m/=10; 
nr++; 


) 


return nr; 

) 

using namespace std; 

int main() 

| 
int n=1,1,X; 
ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 
fl>>n; 
for(i=1;i<=n;i++) 


| 


f1>>x; 
if(x%2==1) 
f2<<nrcifre(x)<<' '; 
) 
return 0; 
) 
8. Din fişierul tip1.in se citeşte un număr natural n cu maxim nouă cifre nenule şi o cifră 


pară k. Să se scrie în fişierul tipl.out numărul care se obține prin eliminarea tuturor cifrelor 
cu valoarea k din x; Exemplu: 

Date de intrare: 1231 2 

Date de ieşire: pe prima linie a fişierului tip1.out se va scrie 131 


include <iostream> 
include <fstream> 
using namespace std; 
int main() 
| 
int n,k,i=1,x[1000]; 
ifstream f1("tip.in"); 
ofstream f2("tip.out"); 


f1>>n:f1>>k; 
int aux=n,m=1; 


while(aux!=0) 


| 
if((aux% 10)!=k) 
| 
x[m]=aux%10; 
m++; 
) 
aux=aux/10; 
) 
for(d=m-1;1>=1;1--) 
f2<<x[i]; 
return 0; 
) 
9. Fişierul puncte.txt conține cel mult 1000 de linii, pe fiecare linie fiind scrise câte două 


numere întregi nenule semnificând coordonatele unor puncte în plan. 
Scrieți un program care citeşte coordonatele punctelor din fişierul puncte.txt şi afişează pe 
ecran numărul de valori care se află în cadranul I; Exemplu: 


puncte.txt ecran 
11 2 


10 1 
-1 1 


#include <iostream> 
#include <fstream> 
using namespace std; 
int main() 


| 


int nr=0,x,y; 
ifstream f("puncte.txt"); 
while(f>>x && f>>y) 


if(x>=0 && y>=0) 
nr++; 
) 


cout<<"Numarul de puncte aflate in cadranul I : "<<nr; 


return O; 


10. Fişierul fractii.txt conţine pe prima linie un număr n cu cel mult două cifre iar pe 
următoarele n linii câte două numere naturale nenule semnificând numărătorul şi numitorul unei 
fracții. Scrieți un program care citeşte datele din fișierul fractii.txt si afişează pe ecran numărul 
de fracții ireductibile scrise în fişierul fractii.txt; 

Exemplu: 

Dacă fişierul fractii.txt are următorul conţinut: 

4 

23 

46 

2411 

6 

atunci pe ecran se va afişa valoarea: 2 


include <iostream> 
include <fstream> 
int emmdc(int a,int b) 
fintr; 
while(b) 
| 
r=a%b; 


return a; 


) 


using namespace std; 
int main() 


{ 


int n,a,b,nr=0,1; 


ifstream f("fractii.txt”); 
[551 
for(i=1;i<=n;i++) 
{ 
f>>a; 
f>>b; 
if(cmmdc(a,b)==1) 
nr++; 


cout<<nr<<' '; 
return 0; 


11. Fişierul atestat.in conține pe prima linie numărul natural nenul n (2<n<10). Pe fiecare 
dintre următoarele n linii sunt scrise câte trei numere reale x , y şi r, reprezentând coordonatele 
carteziene ale centrului unui cerc din planul xOy şi raza acestuia. Cele trei numere x, y sir sunt 
separate prin câte un spaţiu. 

Să se scrie un program, în limbajul /C/C++, care scrie în fişierul atestat.out coordonatele 
carteziene ale centrelor cercurilor din planul xOy şi raza acestora, sub forma (x, y, r) (abscisă, 
ordonată, rază), câte unul pe linie, în ordinea crescătoare a razelor; Exemplu: 


atestat.in atestat.out 
5 (1,3,1) 
131 (3,3,2) 
447 (6,2,3) 
255 (2,5,5) 
332 (4,4,7) 
623 


#include <iostream> 
#include <fstream> 
using namespace std; 
struct cerc 
{ 

int xy; 
Jc[10]; 
int main() 
{int i,n j,aux; 


ifstream f("atestat.in"); 
ofstream g("atestat.out"); 


f>>n; 
for(i=1;i<=n;i++) 
| 
f>>e[i]x; 
f>>cli].y; 


f>>cl[i].r; 
) 
ford=1;i<=n;i++) 
for(j=1;j <=n;j++) 
if(c[i].r<c[j].r) 
{ 
aux=c[i].r; 
c[i].r=c[j].r; 
c[j].r=aux; 


aux=c[i].x; 
cli]: x=clj]:x; 
c[j].x=aux; 


aux=c[i].y; 
eli].y=elj].y; 
elj].y=aux; 
) 
for(i=1:i<=n;i++) 
g<<"("<<c[i].x<<","<<c[i].y<<","<<c[i].r<<")"<<endl; 
return 0; 


) 


12.  Fişierul text numere.in conține pe prima linie un număr natural n (0<n<1000), iar pe a 
doua linie n numere naturale cu cel mult 9 cifre fiecare, despărțite prin câte un spațiu. Scrieți 
un program C/C++ care citeşte toate numerele din fişierul numere.in si care, scrie pe prima 
linie în fişierul de ieşire numere.out, separate prin câte un spaţiu, numerele palindrom de pe a 
doua linie a fişierului numere.in; Exemplu: 


numere.in numere.out 
8 53135 3113 373 239932 313 
53135 3113 61556 373 54 239932 313 122 


include <iostream> 
tinclude <fstream> 
using namespace std; 
int palindrom(int x) 
fint aux=x,inv=0; 
while(aux) 


inv=aux 9% 10+inv* 10; 
aux/=10; 
) 
return inv==X; 
) 
int main() 
(int 1,n,X; 


ifstream f("numere.in"); 
ofstream g("numere.out"); 


f>>n; 


for(i=1;i<=n;i++) 
| 
f>>x; 
if(palindrom(x)==1) 
g<<x<<' '; 


return 0; 


} 


13. Fişierul text numere.in conține pe prima linie un număr natural n (0<n<1000), iar pe a 
doua linie n numere naturale cu cel mult 9 cifre fiecare, despărțite prin câte un spațiu. Scrieți 
un program C/C++ care citeşte toate numerele din fișierul numere.in şi care afişează pe prima 
linie în fişierul numere.out suma cifrelor fiecărui număr din fişierul de intrare; Exemplu: 


numere.in numere.out 
3 10 5 10 
82 500 1234 


include <iostream> 
include <fstream> 
using namespace std; 
int main() 

fint i,n,s=0,x; 


ifstream f1("numere.in”); 
ofstream f2("numere.out"); 


fl>>n; 
for(i=1;i<=n;i++) 
| 
i |: 
s=0; 
while(x) 
{ 
s=x%10+s; 
x/=10; 
) 


f2<<s<<''; 


) 


return 0; 


14. — Fisierul atestat.in conţine două linii. Pe prima linie este scris un număr natural n nenul 
(n<=50) iar pe a doua linie sunt scrise n numere naturale nenule de cel mult 9 cifre separate 
prin câte un spaţiu. Scrieți un program C++ care citeşte din atestat.in numărul n si apoi cele n 


10 


numere si care scrie în fişierul atestat.out media aritmetică a numerelor de pe poziţii impare 
din şir; 
Exemplu: 
Dacă fişierul atestat.in conţine: 
5 
4 2 2 2 6 atunci atestat.out va avea următorul 
conținut: 
4 


include <iostream> 

include <fstream> 

using namespace std; 

int main() 

(int 1,n,x,ma=0,J=0; 
ifstream f("atestat.in"); 
ofstream g("atestat.out"); 


f>>n; 
for(i=1;i<=n:i++) 
| 
L i 
1f(%2==1) 
(ma+=x;j++;) 
) 
g<<ma/j; 
return O; 


15. — Fisierul text numere.in conține pe prima linie un număr natural n (0<n<1000), iar pe a 
doua linie n numere naturale cu cel mult 9 cifre fiecare, despärtite prin cäte un spatiu. Scrieti 
un program C/C++ care citeşte toate numerele din fișierul numere.in, construieşte un vector 
cu aceste numere, si scrie pe prima linie în fişierul de ieşire numere.out, mesajul DA dacă 
numerele din vector sunt prime între ele două câte două şi mesajul NU în caz contrar; Exemplu: 

numere.in numere.out 

7 NU 

5 131 56 14 55 456 513 


tinclude <iostream> 
tinclude <fstream> 
using namespace std; 
int cmmdcf(int a,int b) 
| 
intr; 
while(b) 
t 
r=a%b; 
a=b; 
b=r; 
) 


return a; 
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) 


int main() 
{int x[1001],i,j,n,ok=1; 


ifstream f("numere.in"'); 
ofstream h('"numere.out''); 
f>>n; 
for(i=1;i<=n;i++) 

f>>xlil; 
for(i=1;i<=n;i++) 

for(j=i+1;j<=n;j++) 

| 

if(cmmdc(xli],x[j !=1) 
(h<<"NU'"';i=n+2;j=n+2;0k=0;) 
) 


if(ok==1) 
h<<"DA"; 


return 0; 


) 


16. Numim prefix al unui număr natural x orice cât nenul obţinut prin împărţirea întreagă a lui 
x la o putere a lui 10. 

Fisierul numere.in conține pe o singură linie un şir de cel mult 100 de numere naturale cu 
maxim 9 cifre, separate prin câte un singur spațiu. 

Scrieţi un program care citeşte valorile din fişierul numere.in și scrie în fişierul numere.out 
o valoare ce reprezintă numărul de valori care au un prefix divizibil cu 10; Exemplu: 
Prefixele numărului 12546 sunt 12546, 1254, 125, 12, 1. Dacă fişierul numere.in conține pe 
prima linie valorile: 

103 234 567 613 61 100 345 2103 21 atunci fișierul 

numere.out va avea următorul conținut: 

3 

deoarece sunt trei numere care au un prefix divizibil cu 10 si anume 103, 100 si 2103 
include <iostream> 

include <fstream> 

using namespace std; 

int main() 

(int i,nr=0,x; 


ifstream f("numere.in"); 
ofstream g("numere.out”); 


while(f>>x) 
{ 
while(x) 
| 
1f(x%10==0) 
(nr++;x=0;) 
x/=10; 
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) 
g<<nr; 
return O; 


) 


17. — In fişierul date.in, pe prima linie, este memorat un număr natural n, iar pe linia 
următoare n numere naturale de cel puţin 3 cifre şi cel mult 9 cifre, cu toate cifrele nenule. 
Scrieţi un program C/C++ care afişează pe prima linie a fişierului date.out, valorile obținute 
prin eliminarea primei cifre din fiecare dintre cele n numere citite; 
Exemplu: dacă se citeşte pentru n valoarea 4 şi de pe rândul următor valorile 

234 1567 278 5673 

se obţine în fişierul date.out: 

34 567 78 673 


include <iostream> 
include <fstream> 
using namespace std; 
int main() 

(int x,i,p=1,aux,n; 


ifstream f("date.in"); 
ofstream g("date.out"); 


f>>n; 
for(i=1:i<=n;i++) 
| 

p=1; 

f>>x; 

aux=x; 

while(aux) 


{ 
aux/=10; 
p*=10; 

) 


g<<x%(p/10)<<' '; 


return 0; 


18. — Fisierul atestat.in conţine două linii. Pe prima linie este scris un număr natural nenul n 
(5<n<30). Pe cea de-a doua linie a fişierului sunt scrise n numere naturale separate prin câte un 
spaţiu, formate fiecare din cel mult 4 cifre si cel puțin 2 cifre, reprezentând un sir de n numere 
naturale. Cel puţin unul din cele n numere din şir este număr par. 

Să se scrie un program, care preia valorile din fişierul atestat.in şi scrie în fișierul 
atestat.out separate printr-un spațiu, toate numerele pare din sir în ordinea descrescătoare a 
valorii lor; 

Exemplu: 
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atestat.in atestat.out 
6 6138 496 24 18 12 
6138 12 496 2523 18 1243 


include <iostream> 

include <fstream> 

using namespace std; 

int main() 

(int 1=0,n,j,x[31],a,aux,m=1; 
ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 
fl>>n; 
while(f1>>a) 
| 

1f(a%2==0) 
x[m++]=a; 


) 


for(i=1;i<=m:;i++) 
for(j=1:j<=m:j++) 
1f(x[1] <x[j]) 
| 
aux=x[i]; 
x[i]=x[j]; 
x[j]=aux; 


) 


for(i=1;i<m:i++) 
f2<<x[i]<<''; 


return 0; 


) 


19. — Fisierul text numere.in conține pe prima linie un număr natural n (0<n<1000), iar pe a 
doua linie n numere naturale cu cel mult 9 cifre fiecare, despărțite prin câte un spaţiu. Scrieţi 
un program care citește numerele din fişierul numere.in, verifică dacă numerele de pe a doua 
linie sunt în ordine crescătoare şi scrie pe prima linie a fişierului numere.out unul din mesajele 
Da sau Nu. 


Exemplu: 
numere.in numere.out 
12 Nu 


10 301 23 44 676 43 88 201 702 124 147 90 


*include <iostream> 
tinclude <fstream> 
using namespace std; 
int main() 

(int 1,n,X,y,ok=1; 
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ifstream f1("numere.in"); 
ofstream f2("numere.out"); 


fl>>n; 
f1>>y; 
for(i=1;i<=n;i++) 
| 
=, 
EL>>y: 
if(x>y) 
| 
f2<<"Nu"; 
1=n+1; 
ok=0; 


if(ok==1) 
f2< g a” 


return 0; 


) 


20. — Fisierul atestat.in conţine două linii. Pe prima linie este scris un număr natural nenul n, 
(5<n). Pe cea de-a doua linie a fișierului sunt scrise n numere naturale, separate prin câte un 
spaţiu, formate fiecare din cel mult 9 cifre si cel puţin 2 cifre, reprezentând un sir de n numere 
naturale. Primul număr din şir se găseşte pe poziția 1, iar ultimul număr din şir se găsește pe 
poziţia n. Cel puţin unul din cele n numere din şir are cifra zecilor impară. Să se scrie în fişierul 
atestat.out, separate printr-un spaţiu, toate numerele din sir, care au cifra zecilor imparä. 
Exemplu: 


Date de intrare : 

6 

6138 12 496 2523 18 1243 
Date de ieşire: 

6138 12 496 18 


+include <iostream> 
include <fstream> 
using namespace std; 
int main() 

fint 1,n,x,aux; 


ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 


fl>>n; 
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for(i=1;i<=n;i++) 
| 
Fl55x" 
aux=X; 
if((aux/10)%2) 
f2<<x<<''; 


) 


return 0; 


) 


21. — Se citeşte din fișierul tip2.in de pe prima linie un număr natural n iar pe a doua linie 
n numere naturale. Se cere să se afişeze în fişierul de ieşire tip2.out, valorile cu suma cifrelor 
un număr IMpar. Exemplu : 
Date de intrare: 5 
417 2152 26 664 7 
Date de ieșire: 417 2152 664 7 22? -_-??? 


#include <iostream> 
#include <fstream> 
using namespace std; 
int cifracontrol(int a) 
{ 
if(a<=9) 
return a; 
if(a%9!=0) 
return a%9; 
else return 9; 
) 
int main() 
fint i,n,x,s=0; 


ifstream f1("tip2.in"); 
ofstream f2("tip2.out"); 
fl>>n; 


for(i=1:i<=n;:i++) 
(s=0; 
f1>>x: 
s=cifracontrol(x); 
if(s%2==1) 
f2<<x<<' '; 


return 0; 


) 
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22. Din fişierul text tablou.in se citesc: un număr natural n reprezentând numărul de 
componente ale unui vector cu numere naturale nenule cu cel mult 9 cifre fiecare și cele n 
componente ale vectorului (n<100). Se cere să se afișeze elementele vectorului pe primul rând 
al fişierului text tablou.out, ordonate crescător. Exemplu: 

tablou.in tablou.out 


5 2 25 42 122 313 
25242 313 122 


include <iostream> 
tinclude <fstream> 
using namespace std; 
int main() 

(int x[101],1,j,n,aux; 


ifstream f("tablou.in"); 

ofstream h("tablou.out"); 

12 > 05 

for(i=1:i<=n;i++) 
f>>x[i]: 


for(i=1:i<=n;i++) 
for(j=i+1;j<=n;j++) 
1f(x[1]>x[j]) 
| 
aux=x[i]; 
x[i]=xlj]; 
x[j]=aux; 
) 
for(d=1;1<=n;1++) 
h<<x[i]<<''; 
return O; 


23. Peprimalinieafisierului atestat.in se află un număr natural n, iar pe următoarele n linii 
cäte n numere naturale de maxim 2 cifre separate prin spatii reprezentänd elementele unui 
tablou bidimensional. Scrieți un program C++ care citește din atestat.in numărul n si apoi 
elementele tabloului şi care scrie în fişierul atestat.out numărul de numere prime situate sub 
diagonala secundară; dacă nu este niciun număr prim se va scrie „nu există”. (un număr natural 


n>=2 se numeşte prim dacă nu are alţi divizori decât 1 si el însuşi). 


Exemplu : 
Daca fişierul atestat.in conţine: 
4 
6441 
2681 
0422 


17 


8 6 7 4 atunci atestat.out va avea următorul 
conţinut: 


3 


include <iostream> 
include <fstream> 
using namespace std; 
int prim(int x) 
t 
if(x==1) 
return 0; 
int d=2; 
while(d*d<=x && x %d!=0) 
d++; 
if(d*d>x) 
return 1; 
else return 0; 
) 
int main() 
fint a[101][101],i,j,n,nr=0; 


ifstream f("'atestat.in''); 
ofstream g("'atestat.out''); 
f>>n; 
for(i=1;i<=n;i++) 
for(j=1;j<=n;j++) 
f>>ali][j]; 


fordd=2;i<=n;i++) 
for(j=n+2-i;j<=n;j++) 
if(prim(a[i][j))==1) 
(nr++;) 


if(nr==0) 
g<<"NU EXISTA"; 
else g<<nr; 


return 0; 


24. O matrice pätraticä, A, de dimensiune n, cu p elemente naturale nenule, este memoratä 
economic in fisierul de intrare Matrice.txt sub urmätoarea formä: pe prima linie a fisierului se 
gäsesc douä numere, n si p, dimensiunea matricei respectiv numärul de elemente nenule, iar 
pe următoarele p linii triplete de numere naturale (v, 1, €) care reprezintă valoarea, linia respectiv 
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coloana pe care se găsesc elementele nenule. Scrieți un program care citește informațiile din 
fişierul de intrare, reface şi scrie în fișierul de ieşire Matrice.out matricea A. Exemplu: dacă 
fişierul Matrice.txt are următorul conţinut: 


2 4 38 5 4 atunci fişierul Matrice.out va avea 
următorul conţinut: 


0080 

include <iostream> 
include <fstream> 
using namespace std; 


int main() 

(int a[100][100],1,5,n,p,v,1,c; 
ifstream f("Matrice.in"); 
ofstream g("Matrice.out"); 
f>>n:f>>p; 
for(i=1;i<=p;i++) 

i 
f>>v; 
SSi 
f> >c; 
all][c]=v; 
) 


for(i=1:;i<=n:i++) 
[for(j=1;j<=n;j++) 
g<<ali][j]<<' '; 
g<<endl; 
) 
f.close(); 
g.close(); 


25. — Fisierul atestat.in conține pe prima linie un număr natural n (2<n<20), care reprezintă 
numărul de linii, respectiv numărul de coloane ale unei matrice. Pe fiecare din următoarele n 
linii, sunt scrise câte n numere întregi, formate din cel mult 4 cifre, separate prin câte un spațiu, 
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reprezentând valorile elementelor matricei. Să se scrie un program, care preia valorile din 
fişierul atestat.in si scrie în fişierul atestat.out, separate printr-un spaţiu, numărul de elemente 
prime de pe fiecare coloană a matricei. 

Liniile şi coloanele matricei vor fi numerotate începând cu 1. 


Exemplu: 
atestat.in atestat.out 
3 102 
714 114 
462 
9 22 193 
/[de cand e 2 neprim si ultimul rand cum de contine 2 prime ca eu vad doar pe 
193// 


tinclude <iostream> 
tinclude <fstream> 


using namespace std; 
int prim(int x) 
| 
int d=2; 
if(x==1) 
return 0; 
while(d*d<x && x%d!=0) 
d++; 


return d*d>x; 


) 


int main() 


{int n,a,1,],nr=0; 
ifstream f("atestat.in"); 
ofstream g("atestat.out"); 
Don 


for(i=1;i<=n;i++) 
(for(j=1;j<=n;j++) 


f>>a; 
if(prim(a)) 
nr++; 
) 
g<<nr<<'; 
nr=0; 
) 
g.close(); 
return 0; 
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26. — Fisierul text matrice.in conține pe prima linie un număr natural n (0<n<20), iar pe 
următoarele n linii câte n numere întregi de cel mult patru cifre, separate prin spaţiu, 
reprezentând elementele unei matrice cu n linii şi n coloane. Scrieţi un program care citeşte 
datele din fişierul matrice.in si afişează în fişierul matrice.out cel mai mare număr situat pe 
diagonala secundară a matricei. Exemplu: 

matrice.in — matrice.out 

4 76 

10 20 30 40 

51 82 42 56 

45 76 90 18 

32 114375 


include <iostream> 
include <fstream> 
using namespace std; 


int main() 


| 


int n,mat,i,j,maxi; 


ifstream f("matrice.in"); 
ofstream g("matrice.out"); 
f>>1; 
for(d=1;1<=n;1++) 
for(j=1;j;<=n;j++) 
| 
f>>mat; 
1f(i+j==n+1 && mat>maxi) 
maxi=mat; 
) 
g<<maxi; 
f.close(); 
g.close(); 
return 0; 


) 


27. Fişierul atestat.in conține pe prima linie numărul natural nenul n (2<n<20), care reprezintă 
numărul de linii, respectiv numărul de coloane ale unei matrice A. Pe fiecare din 
următoarele n linii, sunt scrise câte n numere întregi, formate din cel mult 4 cifre, separate 
prin spaţii, reprezentând valorile elementelor matricei A. Să se scrie un program, în limbajul 
C/C++, care scrie în fişierul atestat.out numărul elementelor numere perfecte din matricea 
A; Un număr întreg a se numește perfect dacă este egal cu suma divizorilor mai mici decât 
el, de exemplu 6=1+2+3. Dacă nu există numere perfecte se va scrie mesajul “Nu exista 
numere perfecte”. Exemplu: 
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atestat.in atestat.out 
34 12 

9 4 2 35 

57 -58 23 34 

34 9 -5 69 


6 26 33 28 
TROLOLOLOLO 6 SI 28 sunt numere PERFECTE 


include <iostream> 
include <fstream> 
using namespace std; 
int perfect(int a) 
{ 
int d=1,S=0; 
while(d<a) 
{ 
if(a%d==0) 
S+=d; 
return S==a; 
) 
) 
int main() 


int i,j, A,n,nr=0; 


ifstream f("'atestat.in''); 
ofstream g("'atestat.out''); 
f>>n; 
for(i=1;i<=n;ji++) 
for(j=1;j<=n;j++) 
t 
f>>A; 
if(perfect(A)==1) 
{ 
nr++; 
) 
) 
if(nr==0) 
g<<"Nu exista numere perfecte in fisier"; 
else g<<nr; 
return 0; 


) 


28. Fişierul atestat.in conţine pe prima linie un text de maxim 100 de caractere format din 
litere, cifre şi spații. Cuvintele sunt separate prin câte un spațiu. Primul caracter este o literă. 
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Scrieţi un program C++ care citeşte din atestat.in șirul de caractere si care scrie în fişierul 
atestat.out şirul din care s-au eliminat toate caracterele cifră; Exemplu : 

Daca fişierul atestat.in conţine: 

Gigel are 2 mere si 3 alune 

atunci fişierul atestat.out va avea următorul conținut: 

Gigel are mere si alune 


include <iostream> 
include <cstring> 
tinclude <fstream> 
using namespace std; 
int f[256]; 
int main() 
(char s[205],voc[]="aeiou"; 
int 1=0,n=0,j=0,k=0; 
ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 
f1.getline(s,205); 
for(i=0;s[1];) 
| 
if(isdigit(s[i])) 
strcpy(s+i,s+i+1); 
else i++; 


) 


f2<<s<<"n"; 


return 0; 


) 


29. Fişierul atestat.in conţine o singură linie pe care se află scris un text format din cel mult 
200 de caractere, primul caracter fiind literă, iar cuvintele din text sunt separate prin câte un 
spaţiu. Fiecare cuvânt este format doar din litere mari sau mici ale alfabetului limbii engleze. 
Să se scrie un program care să afişeze textul pe o singură linie a ecranului, scris cu majuscule. 


Exemplu: 

atestat.in 

Imi place Informatica 

Ecran 

IMI PLACE INFORMATICA 
atestat.out 


include <iostream> 

include <cstring> 

include <fstream> 

using namespace std; 

int f[256]; 

int main() 

(char s[205][100],voc[]="AEIOU"; 
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int 1=0,n=0,j=0,nr=0; 

ifstream f1("atestat.in"); 

ofstream f2("atestat.out"); 

while(!f1.eof()) 
(f1>>sf[i];strupr(s[i]);cout<<s[i]<<' ';1++;) 
n=i; 


for(j=0;j<strlen(s[i]);;++) 


| 
if(!strchr(voc,s[i][j])) 
nr++; 
) 
f2<<nr; 
return 0; 


) 


30. Fişierul atestat.in conţine o singură linie pe care se află scris un text format din cel mult 
70 de caractere, primul caracter fiind literă, iar cuvintele din text sunt separate prin câte un 
spaţiu. Fiecare cuvânt este format doar din litere mari sau mici ale alfabetului limbii engleze. 
Să se scrie un program, care preia valorile din fişierul atestat.in şi afişează pe ecran numărul 


de apariţii a primului caracter din text şi apoi textul transformat astfel: litere mari în litere mici 
si litere mici în litere mari; 


Exemplu: 
atestat.in Date de ieşire 
Ana ateStaT colaC elevele feReaStra 6 aNA ATESTAt COLAc ELEVELE FErEAsTRA 


+include <iostream> 

include <cstring> 

tinclude <fstream> 

using namespace std; 

int main() 

(char s[75][100],voc[]="aeiou" lit; 
int i=0,n=0,nr=0,j=0,0k=0,m; 


ifstream f1("atestat.in"); 
ofstream f2("atestat.out"); 


while(!f1.eof()) 
(f1>>s[i]:i++;) 
n=i; 


for(i=0:i<n:i++) 
for(j=0;j<strlen(s[i]):j++) 
(if(s[i][j]>="A' && s[i][j]<'a') 
s[illil+=32; 
else s[i][]]-=32; 
) 
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lit=s[0][0]; 
for(i=0:i<n:i++) 
for(j=0:j<strlen(s[i]):j1+) 
if(s[i][j]==s[01[0] || s[illj]==s[0][0]-32) 


nr++; 


cout<<nr-1<<''; 
for(i=0;i<n;i++) 
cout<<s[i]<<' '; 


return 0; 


) 
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